.reconnect-timeline {
    display: flex;
    gap: 1rem;
    align-items: center;
    position: relative;
    padding: .75rem 0;
}
.reconnect-timeline .dot {
    position: relative;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 2px solid var(--bs-secondary);
    background-color: transparent;
    transition: all .25s ease-in-out;
}
.reconnect-timeline .dot::before,
.reconnect-timeline .dot::after {
    content: "";
    position: absolute;
    top: 50%;
    width: 22px;
    height: 2px;
    background-color: var(--bs-border-color, rgba(0,0,0,.1));
    transform: translateY(-50%);
}
.reconnect-timeline .dot::before { left: -24px; }
.reconnect-timeline .dot::after  { right: -24px; }

/* Cacher les traits aux extrémités */
.reconnect-timeline .dot:first-child::before { display: none; }
.reconnect-timeline .dot:last-child::after   { display: none; }

/* Etats */
.reconnect-timeline .dot--done {
    border-color: var(--bs-success);
    background-color: var(--bs-success);
    box-shadow: 0 0 0 2px color-mix(in oklab, var(--bs-success) 25%, transparent);
}
.reconnect-timeline .dot--active {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 3px color-mix(in oklab, var(--bs-primary) 20%, transparent);
    animation: reconnect-pulse 1s ease-in-out infinite;
    background-image: radial-gradient(circle at center, color-mix(in oklab, var(--bs-primary) 35%, transparent) 40%, transparent 41%);
    background-color: #fff;
}
.reconnect-timeline .dot--future {
    border-color: var(--bs-secondary);
    background-color: transparent;
    opacity: .8;
}

#reconnect-modal .modal-body {
    text-align: center;
}
#reconnect-modal .modal-body .d-flex {
    justify-content: center;
}
#reconnect-modal .reconnect-timeline {
    justify-content: center;
}

@keyframes reconnect-pulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50%      { transform: scale(1.15); opacity: .75; }
}